$$ \newcommand{\floor}[1]{\left\lfloor{#1}\right\rfloor} \newcommand{\ceil}[1]{\left\lceil{#1}\right\rceil} \renewcommand{\mod}{\,\mathrm{mod}\,} \renewcommand{\div}{\,\mathrm{div}\,} \newcommand{\metar}{\,\mathrm{m}} \newcommand{\cm}{\,\mathrm{cm}} \newcommand{\dm}{\,\mathrm{dm}} \newcommand{\litar}{\,\mathrm{l}} \newcommand{\km}{\,\mathrm{km}} \newcommand{\s}{\,\mathrm{s}} \newcommand{\h}{\,\mathrm{h}} \newcommand{\minut}{\,\mathrm{min}} \newcommand{\kmh}{\,\mathrm{\frac{km}{h}}} \newcommand{\ms}{\,\mathrm{\frac{m}{s}}} \newcommand{\mss}{\,\mathrm{\frac{m}{s^2}}} \newcommand{\mmin}{\,\mathrm{\frac{m}{min}}} \newcommand{\smin}{\,\mathrm{\frac{s}{min}}} $$

Prijavi problem


Obeleži sve kategorije koje odgovaraju problemu

Još detalja - opišite nam problem


Uspešno ste prijavili problem!
Status problema i sve dodatne informacije možete pratiti klikom na link.
Nažalost nismo trenutno u mogućnosti da obradimo vaš zahtev.
Molimo vas da pokušate kasnije.

Грамзиви алгоритми

Алгоритми засновани на претрази до решења долазе кроз низ корака где у сваком кораку анализирају неколико могућности. Алгоритми код којих се уместо анализе различитих могућности у сваком кораку узима неко локално оптимално решење називају се похлепни или грамзиви алгоритми (енгл. greedy algorithms). Такве алгоритме обично има смисла примењивати само код проблема код којих постоји гаранција да ће такви избори на крају довести до глобално оптималног решења.

На слици су приказана два дрвета претраге таква да у случају првог дрвета похлепни алгоритам који у сваком кораку бира наследника са највећом могућом вредношћу доводи до оптималног решења (максималне могуће вредности), док у случају другог дрвета похлепни алгоритам доводи до неоптималног решења (вредности која није оптимална).

Дрво претраге код којег грамзиви алгоритам доводи до оптималног решења тј. решења максималне вредности
Дрво претраге код којег грамзиви алгоритам не доводи до оптималног решења тј. решења максималне вредности

Похлепни алгоритми нам, дакле, пружају јасну стратегију (бирај што бољу од свих расположивих могућности) како да у сваком кораку изаберемо једну од више понуђених могућности тако да на крају дођемо до жељеног оптималног решења. У наставку ћемо појам грамзивих алгоритама мало проширити и разматраћемо алгоритме који у сваком кораку бирају само једну могућност на основу неке прецизно дефинисане стратегије, тако да ти избори гарантују да ће се на крају доћи до жељеног (исправног тј. оптималног) решења проблема.

Похлепни алгоритми не врше испитивање различитих случајева нити исцрпну претрагу и стога су по правилу веома ефикасни (у сваком кораку је извршено максимално могуће одсецање). Такође, обично се веома једноставно имплементирају. Са друге стране, као и код свих других алгоритама у којима се користи одсецање, потребно је унапред доказати да се похлепним алгоритмом добија коректно тј. оптимално решење, што у неким случајевима може бити веома изазовно. Само налажење исправног похлепног алгоритма (тј. стратегије) може представљати озбиљан изазов и често није тривијално одредити да ли за неки проблем постоји или не постоји похлепно решење.

Код неких проблема похлепни алгоритми не доводе увек до оптималног решења, али се може доказати да ће решења која се добијају бити квалитетна и неће се пуно разликовати од оптималних, што може оправдати употребу похлепних алгоритама (јер они могу бити много ефикаснији од исцрпних алгоритама који гарантују оптималност). У том случају похлепни алгоритми су хеуристике (технике које не гарантују да ће увек довести до оптималног решења, али који доводе до довољно добрих решења).

Алгоритми засновани на претрази или на динамичком програмирању обично у сваком кораку разматрају више могућности (којима се добија више потпроблема) и након разматрања свих могућности бирају ону најбољу. Дакле, избор се врши тек након решавања потпроблема. За разлику од тога грамзиви алгоритми унапред знају која могућност ће водити до оптималног решења и избор врше одмах, након чега решавају само један потпроблем. У случају оптмизационих проблема и у случају грамзивих алгоритма потребно је да важи својство оптималне подструктуре тј. да се оптимално решење полазног проблема добија помоћу оптималног решења потпроблема.

Да би се доказала коректност похлепног алгоритма, обично је потребно доказати неколико ствари. Иако ћемо некада грамзивим алгоритмима решавати проблеме у којима се захтева да се испита да се провери да ли постоји неко решење које задовољава дате услове и да се пронађе било које такво решење, најчешће ћемо разматрати проблеме у којима се захтева да се у групи решења која задовољавају неке дате услове (исправних решења) пронађе оно оптимално (у случају када постоји више таквих оптималних решења обично је довољно да се пронађе било које).

  1. Прво је потребно доказати да похлепна стратегија даје решење које је исправно тј. решење које задовољава све услове задатка.

  2. Након тога је потребно доказати и да је решење добијено похлепном стратегијом оптимално. Ти докази су по правилу тежи и постоји неколико техника како се они изводе. Обично се крене од неког решења за које претпостављамо да је оптимално и које не мора бити идентично ономе које смо добили похлепном стратегијом. Оно не може бити горе од решења нађеног на основу похлепне стратегије (јер она враћа једно коректно решење, па оптимум може бити само евентуално бољи од тог решења), а потребно је доказати да не може бити боље.

    • Једна техника да се оптималност докаже је то да се покаже да се оптимално решење мало по мало, применом трансформације појединачних корака може претворити у решење добијено на основу наше стратегије. Обично је довољно доказати да се први корак оптималног решења може заменити првим кораком који грамзива стратегија сугерише, тако да се коректност и квалитет решења тиме не нарушавају и коректност даље следи на основу индуктивног аргумента. Ову технику називаћемо техника размене (енгл. exchange).

    • Једна техника да се оптималност докаже је то да се докаже да је решење добијено на основу похлепне стратегије увек по неком критеријуму испред претпостављеног оптималног решења. Ову технику називаћемо похлепно решење је увек испред (енгл. greedy stays ahead).

    • Једна техника да се оптималност докаже је да се одреди теоријска граница вредности оптимума и да се онда докаже да похлепни алгоритам даје решење чија је вредност управо једнака оптимуму. Ову технику називаћемо техника границе (енгл. structural bound).

Грамзиви алгоритми — задаци

Реч у реч прецртавањем слова

За овај задатак можете видети решење
покушало: 308, решило: 93%

Жаба на камењу

покушало: 356, решило: 71%

Неопадајућа растојања суседних елемената

покушало: 123, решило: 68%

Шаховске екипе

За овај задатак можете видети решење
покушало: 244, решило: 84%

Ментори

покушало: 266, решило: 83%

Распоред са најмањим бројем учионица

покушало: 78, решило: 66%

Распоред активности

За овај задатак можете видети решење
покушало: 122, решило: 77%

Зли учитељ

За овај задатак можете видети решење
покушало: 407, решило: 64%

Мали поштар

За овај задатак можете видети решење
покушало: 246, решило: 87%

Минимална сума два броја формирана од датих цифара

покушало: 150, решило: 70%

Најмањи број надовезивањем више бројева

За овај задатак можете видети решење
покушало: 107, решило: 79%

Излог са два реда књига

За овај задатак можете видети решење
покушало: 35, решило: 40%

Гласници

За овај задатак можете видети решење
покушало: 68, решило: 76%

Мост

За овај задатак можете видети решење
покушало: 142, решило: 71%

Спасавање чамцем

покушало: 80, решило: 87%

Квалитетни радници

покушало: 26, решило: 46%

Кодирање текста са што мање битова

За овај задатак можете видети решење
покушало: 4, решило: 25%

Распоред са најмањим закашњењем

За овај задатак можете видети решење
покушало: 46, решило: 73%

Разломљени ранац

За овај задатак можете видети решење
покушало: 60, решило: 61%

Селидба

покушало: 93, решило: 39%

Исплата са посебним новчићима

За овај задатак можете видети решење
покушало: 104, решило: 94%